import router from '@/router'
// 引入进度条和样式
import NProgress from 'nprogress'
import 'nprogress/nprogress.css'
import store from './store'
/**
 * 前置守卫
*/
const whiteList = ['/login', '/404']
router.beforeEach(async(to, from, next) => {
  NProgress.start()
  next()
  // 判断token是否存在
  if (store.getters.token) {
    if (to.path === '/login') {
      next('/')// 跳转到首页
      // next（地址）不会执行后置守卫
      NProgress.done()
    } else {
      next() // 放行
      // 通过用户userId判断是否有资料
      if (!store.getters.userId) {
        await store.dispatch('user/getUserInfo')
      }
    }
  } else {
    // 没有token
    /**
     * 1.如果是登录页，直接放行
     * 2判断是否为白名单页面，是就放行
    */
    if (whiteList.includes(to.path)) {
      next()
    } else {
      next('/login') // 跳转到登录页
      NProgress.done()
    }
  }
})

/**
 * 后置守卫()
 *
 */

router.afterEach(() => {
  NProgress.done()
})

